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Process to expand data density 
BACKGROUND OF THE INVENTION 
1. Field of the invention 

The invention relates to a process for transmitting 
information over an electrical or optical support. It deals 
more specifically with the transmission of digital 
information flowing serially in a time sequence over the 
support . 

2. Brief description of the background of the invention, 
including prior art 

It is known for a long time to transmit information in 
serial sequence over an electrical support with various 
methods. For instance, numerous processes and systems are 
known for the purpose of transmitting information between 
musical instruments according to the MIDI interface 
standard (Musical Instruments Digital Interface, MIDI 
Manufacturers Association, The complete MIDI 1.0 detailed 
specification", document version 95.1 section 2 embedding 
2-.doc version 4.2 , Oct 1994 pages 1 to 3) . Due to the MIDI 
specification requiring the use of optoisolators , the . 
information is also conveyed as light modulation. 
Frequently, according to the coding of the information 
peculiar to the transmission process considered, it is not 
uncommon to be limited by the number of different coded 
messages the transmission process can pass along over the 
support, in the case of the MIDI standard, for instance, 
one quickly comes up against the absolute limit of 16 
addresses (also called channels) of various distinct 
instruments that the system is able to cope with. 
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It is therefore desirable to expand the data density of the 
transmitted information, while keeping the previous 
admitted standard for transmitting the information, by 
"superposing" the additional information. 
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SUMMARY OF THE INVENTION 

1. Purposes of the invention 

The invention aims to remedy the drawbacks of the known 
processes by offering a process that allows increasing the 
amount of various distinct messages the system is able to 

convey while maintaining the compatibility with existrng 

systems . 

in the present context a message is defined as a series of 
bits corresponding to one or more instructions and/or to an 
address . 



2. Brief description of the invention 

To this end, the invention deals with a process for the 
transmission of a larger quantity of information between at 
least two devices according to which the elements of 
information which are succeeding each others in time are 
passed along over an electrical or optical support, said 
information elements being made of a packet of binary 
transitions forming bits, said bits being assembled in 
messages which comprises one or more data and/or addresses 
of the devices for which these data are intended, while 
said process remains unobtrusive to pre-existing systems 
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and nevertheless allows the increase of the amount of 
various distinct messages the system is able to convey. 

The invention is making use of the peculiarities of the 
methods commonly used to recognize a message . in order to 
add supplemental information in a non-obtrusive manner. 

According to the invention, additional binary bits are 
inserted between the bits forming the initial message. The 
positioning and time length are chosen in order to avoid 
the recognition by the usual known methods of message 
retrieving. Said methods of message retrieving are based on 
a logic circuitry called UART (Universal Asynchronous 
Receiver /Transmitter, see for example Atmel Document: ref 
1042D-04/99/XM about AT902333 & 4433 microcontrollers, 
embedded UART pages 44 to50) . 

Only a receiver based on message reading according to the 
invention will be able to retrieve the entire content of 
the message including the additional bits. 

By information, it is intended to designate any message in 
which the semantic content may be coded. 
According to the invention, devices are information 
transmitters, information receivers, or combined . . . 

information transmitters and receivers (transceivers) . 

According to the invention, the information elements are 
succeeding each other in time over an electrical or optical 
support. By "succeeding each other", it is meant a 
transmission of the information elements one by one in a 
time sequence, any element using alone the whole 
information capacity of the support. By electric support, 
there is meant any means able to convey an electrical 
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-nother Those supports will be 
sig nal fro. a point to ano^e- ^ ^ 

mostly realized by means isolat ed between them 

- - o, one o :::::: ^ connectors . 
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.■on the information elements are 
^ t-he invention, tne 
fi ccord a ng to the r transitions , called bits, 

made of a set of binary ^ ^.^ q£ the 

succeeding each other »t» a fcinary 

in£ ormatlon is done by means ^ ^ 

transition is performed by a s ^ conv ersely 

res t-voltage to the ^ Z^^ ^ *° ^ 
from the on-voltage to th > * Qther „ se ts of 

whe n the coding is fche devices connected over 

bits, form messages dedicate 

th e eiectrical or optical support. 

t t-he binary information 
M advantageous ^^f, . coding done by 

£io " in9 ri u :r:„: —/to ~, *. 

means of a current. presence or 

lovpls are materialized cy 
two binary levels a matt er whether the 

ant It does not matter 
absence of a current . abse nce or by the 

bi nary level x ^^^l,. a realisation having 
presence of the uherein the bina ry level 1 rs 

shown good results IB ^ fe . nary . level 

materialized by the absence of curre 

0, by its presence. 
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According - the invention, addition*! brts •» 
between the bits o£ an original message . Each o£ the 
Clonal bits is centered at the moment o £ time whrch was 

one of transition between bits in the original message. 
5 1 amount of supplementary variations in messages a lowed 

bY the insertion of binary bits in a system wherein the 

usages comprises n bits in series is given by the 

following formula: 

10 nsup=2( n - 1) 

Where n is an integer value giving the number of bits in 

the original message. 

15 The invention appears particularly advantageous when it is 

• 4= related to musical 

applied for the communication o£ data related 

equipment according to the MIDI communicate 
According to this use, a 5 mA current codrng rs used for 
"e logic level 0 and said current is stopped for the ogre 
20 "Level 1 The basis frequency of such a MIDI communrcatron 
system is of 31250 Baud and relies on an asynchronous 
' transmission protocol each message comprising a brt 
setting the beginning of the message ("start-bit at the 
- active state, i.e. the- state .,, 8 data bits and one brt 
25 for the end of the message ("stop-bit" at the rest state, 
i.e. the state 1) - 

Similarly, because the MIDI communication standard requires 
the use of opto- isolators, the electrical coding rs 
30 implicitly converted inside these opto-isolators to optical 
coding where a logic level 0 is represented by a photon 
flow between the built-in light-emitting diode and the 
phototransistor, and a level 1 by the absence of photons. 
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, **rA the connectors located at 
~ t-n t-he MIDI standard, tne 
According to the M in£ormat ion support are 

the end o£ the cables o£ the ^ p . ns 

normalized S Pin D X N -J h 1 r ction o£ the current 
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c also a system for the communication 
The invention concerns also a sy 

ine J-"* ..u t he process or tne 

-in accordance witn cne 
o£ in.or.at.on ,n acc ^ communicati on of 

inVenti : n on re a La t o the operation o £ musical devices 

information reiateu 

according to the MIDI standard. 
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in the accompanying drawings: 

transmission according^ sta^ with and without 
. Fig . 3 shows compared txmrng 9 invent ion, with 

additional bits inserted according to 
the associated sampling methods 

. Fig . 4 shows ^re^iming se^es^o ^ ^ 

irr 9 :: z - — — 

of the latter^ method £or ret rieving the 

, Fig. 5 and 6 illustra , iana l against 

signal by comparing the changes rn the srgna 

timing references. 
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DESCRIPTI0N o, — - >— " m 

h stat e of the art; 
Figure x shows a device -^^ ica : - 
it ie £u rther to s fio „ ing over the 

present invention. 4 and 5 o£ th e 

support enters the dev.ce IH> connected to an 

normalised DIH connector ^ £lQW oE 

decoupler 4 via tne optoc o U pler « is then 

. , - nr , q 5 coming out oj- ^ 
binary trans.trons conver ter 6 which is 

-* " a . Ser ;tnn ortion in order to — the 
de _serial— g the, . ^ connecCl on 7 to 

messages. The ^^^^^ generated hv the 
processing unit .. ^ conne ction 9 to be 

processing unit 8 are conver ter 10 which is 

serialized in parallel-to , labe lled DOT) via 

c nf DIN connector 
connected to pin 5 of DIN 
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■i-o nin 5 connected to 
-, n thru) has its pi" ? 

z :::rr:,'r:r. i— — - 

of a asynchronous serial 
Figur e , shows the timing se^ence^ ^ ^ ^ .. ^ ^ 
transmission according ^ sCate x 

fl ow is represented hy arrow ^ corresponds to 

corresponds to level 1 . The 
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vi- a typical message 
wording to the f it s - * 

comprises a start Bit a io ^. ch 1S at 

- T \ r^lLT-U Is initiated h y a transition 
logic level 1, tne o 
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H from level 1 to level 0. Level 0 is maintained for 
duration 2; the combination of this transition 11 and 

.-v,^ Qi-a-rt Bit At the end or 
duration 2 represents the Start ait. 

Nation 2 a level transition » may possibly 

the level o£ the first Data Bit 3 of the message^ A 

5 Bit can be either level 0 or level 1. At the end o 

duration 3. whose length is equal to duration 2, a level 

transition 13 may possibly occur to set the level of the 

second Data Bit 4 of the message. Xt goes snarly for 

the following Data Bits up to the last Data Bit 5 of 

« at the end of which 14 the logical level must go 

message, at tne eiw ^ 

to level 1 for a duration 6 whose length is also eo.ua to 
all other bits 2 to 5 of the message. This bit 6 at level 
! is the Stop Bit, at the end of which 15 a level 
transition from ! to 0 may possibly occur to initiate the 
15 start Bit of the next message. Alternatively, at moment 15 

to level 1 at a rest state. 

I„ order to read the content of the message, the signal is 
20 sampled at predefined time intervals. Typically, the 
receiving devices is synchronizing with the incoming 
receiving times finer than the 

message with a resolution which is 16 times fl 
duration of a bit, here called the clock duration or 
Clock. After the Start Bit transition 11 is detected, the 
25 £ir st Data Bit value will be Known by sampling the signal 
24 Clocks after transition 11. This sampling moment 

i^ 35 „ . „ f the duration of the first Data 

corresponds to the middle of tne au 

Bit From then on, the subsequent Data Bits will be 
sampled at 16 Clock intervals up to and including the last 
30 Data Bit 5, -f-rom where another 16 Clock interval will occur 
b e £or e sampling the Stop Bit to ensure it is effectively at 
level 1 and that the whole message is reliable. 
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an improved method compared to the one described hereabove 
is relying on a^ple^ampl ing of the bits. In this 
method, each bit to be sampled is sampled, tor example, a 
first time 7 at, assuming the above typical 

synchronization, 7/16th of its total duration, the second S 
and third 9 sampling occurring then respectively at B/16th 
and 9/lSth of the total bit duration. The three values 
obtained are processed through a majority vote to determine 
the value of the bit. 

The purpose of this triple sampling is to avoid a false 
reading due to a possible glitch during the signal 
transmission, in which case the probability is high to have 
only one of three samples presenting a faulty value. It 
should be noted that the second sampling, appearing at 
8/16th, is corresponding to the single sampling of the 
original unimproved method described above. 

F igure 3 deals with the heart of the invention and shows 
the timing of an enriched message (16 to 20> . An enriched) 

orcordincr to the invention, 
message is a message that, according 

contains additional bits l^ni^ ■ The bits_21^23_are 
forming a basic message according to the state of the art 
and are called hereafter Ba^nata^ts . The time flow is 
represented by arrow 13. The logical state 1 corresponds 

state 0 corresponds to level 15. 
to level 14. The logical state c v , „ . „_ 

In the basic message ,21 to 23), a bit 22 is a level (14 or 
1S ) for the duration 6 between the possible transitions 10 
and 11. Points 7, 8 and 9 represent the typical triple 
, sampling as described in the discussion of figure 2 . 

The enriched message (16 to 20) shows how additional bits 
17 and 19 are added to the basic message. In this enriched 
message, the duration 6 of bit 22 is reduced to duration 
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24, which is half of initial duration 6 and becomes bxt 
18 Similarly, bit 21 is reduced to become bit 16 and bxt 
23 is reduced to become bit 20. It is important to note 
that bit 21 may be a Data Bit similar to bit 22 but may 
also be the Start Bit. Likewise, bit 23 may be a Data Bxt 
similar to bit 22 but may also be the Stop Bit. This time 
reduction of the bit lengths makes room for additxonal 
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bits 



According to the invention, additional bit, can only be 
inserted between Basic Data Bits, between the Start Bxt and 
the first Basic Data Bit or between the last Basic Data Bxt 

and the Stop Bit . 

in the above example, an additional bit 17 appears centered 
around the transition 10 between what were previously bxt 
21 and bit 22, now respectively bit 16 and bit 18; bxt 19 
is added similarly between bit 22 and bit 23, now 
respectively bit 18 and bit 20. 

in the following description, legacy devices are defined as 
data transmission devices being able to transmit and 

„„!,,. w ~ define new devices as data 
receive basic messages only; we aerxne 

• -™ ^vires beinq able to transmit and receive 
transmxssxon devices oexny a~ 

both- basic and enriched messages. 

The purpose of the invention is to allow the addition of 
bits to an existing message in a transparent manner so that 
legacy (prior art unadapted) receiving devices wxll be 
unaffected by the enriched message while still reading the 
basic message contained within the enriched message. 

This allows the use of both legacy devices and new devices 
implementing the invention, where basic messages and 
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enr iched usages can be exchanged between any of these 

t-voe where basic and enriched messages can be 
devxce type, where enric hed messages won't 

■ vw new devices wniie eiux 

Th is is made possible by the fact that the «^ : ;-f ing 

«, of the bit 22 in the basic message (21 to 
(7 elective when «Un g bit IS in the enriched 

Z (. to 20, while, at the same time, an additional 
message (16 to ^ Qf 

"i Ple "l - "cally, additional bits 1, ana 1, 
additional bit 17 d ^ = bits 

24 . In all these bi , The figure 3 example is built 

and 5/Sth of their duration^ The g ^ ^ 

5 on a bit length reduction to a half 

have a length similar to the basic bits after 
are reduced. 

• « nf length reduction can be applied to 
Other proportions of length reduct ion of the 

20 • . 1aT - result. For instance, a reducuio 

achieve similar result. 

0 f their initial lengca 
basic bits to 60* of the! bit 

■ • i hits with a duration equaling 40. 01 

3ddlt such option might be preferred when reading 

dUrat r di£ e«nt than the triple sampling method described 

25 m " h ° dS * ^ "hosen Any other value for the percentage 

pr eviously are chosen^ y ^ 

of reduction can be used to * 

Figure 4 illustrates the effect a, |*o* speea 

the " h suc P h clock discr epan=ies. The time 

sealing the Umits of such c i ^ ^ ^ 

flow is represented by arrow 13. The m a 

» . „„ fh , state of the art with its Start 
message according to the state 
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Bit s, several Data Bits such as Data Bit 6 and a Stop Bit 
7 The message 2 is an enriched message according to the 
invention and using a basic data bit duration reductron 
50* with its Start Bit 5, several Data Bits reduced rn 
le ngth as explained in figure 3 such as Data Bit S and 
* severai additional bits aiso as expiained in figure 3 - 
as additional bit 9 , it also ends with a Stop Bi 7 The 
message 3 has the same structure as message 2 but only at a 
faster clock rate inlying an overall shorter message. The 
message 4 has the same structure as message 2 but only at a 
■° slower clock rate implying an overall longer message. 

When there is no clock difference between the transmitter 
and the receiver, the triple sampling method already 
described falls perfectly centered in all Data Bits both 
15 Basic and Additional, and that the triple sampling of the 
Stop Bit occurs at 3/8th, 4/8th and 5/8th of its now 
reduced time duration as the theory in figure 3 implies. 
When there is a discrepancy between transmission and 
reception clock rates, there is a risk that the trrple 
20 sampling of the last Data Bit or the triple sampling of the 
"op Bit fall out of range. This fact, which also exists 
in legacy communication systems, leads however to 

of a smaller clock discrepancy when applying the 

acceptance of a smaiiex 

invention due to the narrower bit durations . f"*"**! 
25 where all bits in legacy messages are 16 Clock long the 
enriched message according to the inventio n will hav ts 
D ata Bits 8 Clock long, its Start and Stop Ext. 12 clocK 
each According to these metrics, a legacy message of 

v. „ nat. Bit 6 is 160 Clocks long from 
eight Data Bits such as Data Bit 6 is 

30 12 to 17 (8X16 Clocks ♦ Start Bit 5 - 16 Clocks, ♦ stop Bit 
n - 16 Clocks) . According to the same metrics and using 
for this example a bit reduction of a half (50%) , an 
enriched message 2 of eight Basic Data Bits such as Data 
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Bit 8 and nine Additional Bits such as Additional Bit 9 is 
160 Clocks long from 12 to 17 ( <8 + 9> x 8 Clocks + Start Bit 
5 = 12 Clocks + Stop Bit 7 = 12 Clocks) . 

A typical triple sampling method as explained in figure 3 
will imply that the last sampling 14 of the last additional 
bit 9 in message 2 will occur at 145 clocks in reference to 
time 12. The calculation is : Start Bit = 12 Clocks + (8 
Basic Data Bits x 8 Clocks) + (8 Additional Data Bits x 8 
Clocks) + 5 Clocks. in the same message 2, the transition 
15 marks the end of the last additional data bit 9 and at 
the same time the beginning of the Stop Bit 7 . This 
transition 15 occurs at 148 Clocks. The calculation is: 
Start Bit = 12 Clocks + (8 Basic Data Bits x 8 Clocks) + (9 
Additional Data Bits x 8 Clocks) . In the same message 2, 
the first sampling 16 of the triple sampling of the Stop 
Bit 7 occurs at 151 Clocks. The calculation is: Start Bit 
= 12 Clocks + (8 Basic Data Bits x 8 Clocks) + (9 
Additional Data Bits x 8 Clocks) + 3 Clocks. 

The shorter total duration of message 3 compared to message 
2 can be the result of a sender being faster than the 
receiver or a receiver being slower than the sender; in 
both cases, there is a risk that the last sampling 14 of 
the last additional data bit 9 which normally occurs after 
the duration 10, falls at the transition between the last 
additional data bit 9 and the Stop Bit 7. To keep the 
entirety of the triple sampling of the last additional data 
bit 9 within functional limits, the transmitter speed can 
not be faster than (1/(1/148 x 145)) = 1,020689... times 
the receiver speed. 

The longer total duration of message 4 compared to message 
2 can be the result of a sender being slower than the 
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receiver or a receiver being faster than the sender; in 
both cases, there is a risk that the first sampling 16 of 
the Stop Bit 7 which normally occurs after the duration 11, 
falls at the transition between the last additional data 
bit 9 and the Stop Bit 7. To keep the entirety of the 
triple sampling of the Stop Bit 7 within functional limits, 
the receiver speed can not be slower than (1/(1/148 x 151)) 
= 0,980132 ... times the transmitter speed. 

A practical implementation of the invention compliant with 
the MIDI standard is also relying on figure 1 where all 
elements are similar to the state of the art to the 
exception of block 6 where the serial to parallel 
conversion is not effected by a standard off-the-shelf UART 
(Universal Asynchronous Receiver-Transmitter) but by a fast 
microcontroller (brand Scenix, type SX-18) wherein software 
routines take in charge all the necessary signal 
recognition and samplings. Similarly, the block 10, 
parallel to serial conversion, is also not effected by a 
UART, but by another set of software routines running 
within the same SX-18 microcontroller. As in MIDI, the 
total duration of a message is 320 microseconds, the 
connectors 1, 12 and 14 are of type 5 pin DIN 18 0° female, 
voltage levels are TTL compliant, opto-coupler is of brand 
Sharp, type PC 90 0. - 

The above example intends to describe the invention in a 
practical application without however limiting its scope 
which is not limited to the MIDI environment. 

According to another aspect of the invention, to overcome 
the narrow allowance in speed discrepancy when using the 
triple sampling method, there is disclosed another way of 
retrieving the signal. 
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This method is described with reference to fig. 5 and 6 , 
the numbers in the text are referring to fig. 6 only. 

in this new method, the signal is not checked during the 
stable phase of the individual bits, but by comparing the 
changes in the signal against timing references. 
The method according to this embodiment of the invention 
can be implemented in a microcontroller, relying on 
built-in peripherals and program execution, or in hardware 
only, using standard logic and counters. 

in both cases, two timer/counters are used: the first, 
called CAPTMR, is restarted each time a level change is 
detected. The second one, called EOWTMR, is used in 
determining the end of the message in case there are no 
level changes to make the. last bit or bits of the message. 

Whichever the implementation (hardware or software) , the 
following hardware functional blocks are required: 
- An input pin must be able to trigger the storage of a 
counter/timer value into a register. This counter/timer is 
an up-counter called CAPTMR (Capture TiMeR) . The mentioned 
triggering must be able to generate an interrupt for 
software processing or activation of the required circuit 
in case of hardware-only implementation. The interrupt must 
be maskable. The counter/timer must be restartable . Its 
count duration must be long enough to equal the duration of 
the EOWTMR. The triggering must be selectable between 3- 
modes: disabled, falling edges only, falling and rising 
edges 

- Another counter/timer, called EOWTMR (End Of Word TiMeR) 
is a down-counter used to determine the end of the message. 
This counter/timer must be able to count to a time point 3, 
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somewhere within the Stop Bit, and whose exact value will 
be explained later. It must generate an interrupt at the 
end of count . This interrupt must be maskable . 

. A register, called CAPVAL, to copy and manipulate the 

value initially captured in CAPTMR 

- A register, called ASSEMBLED MESSAGE , where the decoded 
word is assembled bit by bit. 

- A register, called BITPNTR , used as a pointer to the 
individual bits of the ASSEMBLED MESSAGE register 

- A single bit flag register, called POL FLAG, used to 
define the polarity of bits to assemble. 

The rest of the method can be explained with reference to 

logic circuitry or programming into a 

microprocessor /microcontroller with equal results. 

The method is also relying on a status, able to adopt one 

of the 3 following states: REST, START, and RUN. 

REST is the state corresponding to the period between 

v,-r, line is idle and the system awaits a 

messages, when the line it» 

Start Bit. 

The START state is corresponding to the moment between the 
detection of the Start Bit falling edge and the next change 
in the signal (sometimes up to the Stop Bit in case all 
Data Bits are zero)-, or to the EOWTMR end-of -count . 
The RUN state is following the START state, and corresponds 
to the moment between the next change on the signal once 
the START state was activated and the logical conclusion 
that all Data Bits are known, or to the EOWTMR 
end-of -count . 

When the message is over and all bits are known, the state 
loops to REST. 
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At initialization (see TNIT routine), EOWTMR is stopped, 
the system state is REST , and the input capture circuitry 

is allowed to detect falling edge signals only and generate 

interrupts . 

When the input signal which was at rest state 12 is now 
falling to level 13, at moment 1, the capture hardware is 
activated and generates an interrupt. 

The INPUT CAPTURE INTERRUPT routine is then called, 
performing the following operations: 

Duplicate the value held in CAPTMR into CAPVAL, reset and 
start CAPTMR. 

Because the current status is REST, EOWTMR is reloaded and 
allowed to count, the state is changed to START, BITPNTR is 
set to point to bit zero of ASSEMBLED MESSAGE, POL FLAG is 
reset, and the input capture circuitry is allowed to react 
on both polarities of the input signal. The system is now 
waiting for one of the two possible events: a change on the 
input signal, or the end-of-count of EOWTMR. 

According to a first possibility, if no change to the input 
signal occurs, the EOWTMR reaches its end-of-count and the 
EOWTMR INTERRUPT routine is called. This routine executes 
the following operations: stop the EOWTMR, fill the bits of 
ASSEMBLED MESSAGE with the current POL FLAG value until the 
value of BITPNTR is bigger than the constant LAST (of value 
17 in our application) expressing the last Data Bit in the 
message. After that, the ASSEMBLED MESSAGE, containing all 
zero value Data Bits, is saved for further processing, the 
STATE is defined as REST, and input capture is only allowed 
on falling edges of the input signal. The routine is then 



over. 



Th e other possibility implies that the input signal changes 
at least one time before EOWTMR reaches its end-of -count . 
At this START state, the INPUT CAPTURE INTERRUPT routine, 
will execute the following steps: copy CAPTMR to CAPVAL, 
change the state from START to RUN, set the POL FLAG to 1. 
subtract to CAPVAL the value representing the duration of a 
Data Bit , represented as duration IS and called TBIT. The 
remaining value is compared to TBIT. This leads to two 
possible routes. If smaller, it means that the first Data 
Bit 6 is at level 12, the bit in ASSEMBLED MESSAGE 
currently pointed to by BITPNTR is filled with the current 
value of POL FLAG which is one. BITPNTR is incremented, 
pointing now to the second Data Bit. POL FLAG is then 
inverted. The last part of the routine checks if BITPNTR is 
bigger than the constant LAST, which cannot be true at this 
point. However, if the value remaining in CAPVAL is bigger 
than TBIT, it means that at least the first Data Bit is 
equal to zero. In this case, the bit in ASSEMBLED MESSAGE 
currently pointed to by BITPNTR is loaded with the reverse 
of the value in POL FLAG. BITPNTR is incremented before 
looping back into the routine at the point where TBIT 
constant is once again subtracted from CAPVAL, leading to a 
new comparison and so on. 

The whole system is based on comparisons between the value 
reported by a counter/timer CAPTMR over the duration of one 
or several bits, possibly including the start bit, and the 
remaining value after successive subtractions to determine 
how many bits of the same polarity where covered. The 
complementary mechanism assuring that the message 
recognition can not fall out of sync in case there are no 
transitions during the last bit or bits of the message, is 
done with another timer/counter EOWTMR. Its ideal duratxon 



is the point in time 3 equally distant in terms of 
percentage between the beginning 2 of the last Data Bit 7, 
and the end 4 of the Stop Bit 8. This point x is given by 
the following formula where y is the duration between 
moment 1 and 2, z is the duration between moment 1 and 4. 
x = sqr(y . z) 

For ease of comparison, and according to the metrics used 
in the triple sampling example where the whole message had 
a duration of 160, the point 2 equates 140, and the point 4 
equates 160. The formula then gives 149.6662955... as the 
optimal duration for EOWTMR. This translates to a 
theoretical 6.9% of tolerance in clock variation compared 
to the +/- 2% offered by the triple sampling method. 
Nevertheless, the effective tolerance is in fact given by 
the following formula: 
x = T/M 

where x is shown as duration 9 on the drawing, T is the 
duration of TBIT 15, and M is the duration comprised 
between points 1 and 4 . 

Continuing with the same metrics, the practical formula 
become x = 5/160. The practical tolerance of the system to 
clock discrepancies is 5%, an improvement of 2 . 5 compared 
to the triple sampling method. 



While the invention has been particularly shown and 
described with references to a preferred embodiment there 
of, it will be understood by those skilled in the art that 
the foregoing and other changes in form and details may be 
made therein without departing from the spirit and scope of 
the invention. 



